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Abstract. The Herschel Interactive Processing Environment (HIPE) was developed 
by the European Space Agency (ESA) in collaboration with NASA and the Herschel 
. Instrument Control Centres to provide the astronomical community a complete environ- 

J> " ment to process and analyze the data gathered by the Herschel Space Observatory. One 

t— I , of the most important components of HIPE is the plotting system (named PlotXY) that 

■ we present here. With PlotXY it is possible to produce easily high quality publication 
ON 1 ready 2D plots. It provides a long list of features, with fully configurable components, 

and interactive zooming. The entire code of HIPE is written in Java and is open source 
j^. ■ released under the GNU Lesser General Public License version 3. A new version of 

f^*) ' PlotXY is being developed to be independent from the HIPE code base; it is available 

£NJ . to the software development community for the inclusion in other projects at the URL 

t— I ■ |http : //co de . google . com/p/jplot2d/| 

>'■ 
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W . 1. Introduction 



The Herschel Space ObservatorjQ (?) is an ESA cornerstone mission developed in 
collaboration with NASA. It consists of a space telescope with a primary mirror of 3.5 
meters equipped with three scientific instruments (HIFI, PACS, and SPIRE; ???) to 
observe the universe in the far infrared and submillimeter spectral region (from 50 to 
670/rni). 

Herschel was launched on 14th May 2009 together with the ESA Planck mi- 
crowave observatory; its mission lifetime is expected to be of 3.5 years. Herschel is 
operated as an observatory open to the international scientific community, with 1/3 of 
the total time reserved to the consortia institutes that built the scientific instruments. 



1 Herschel is an ESA space observatory with science instruments provided by European-led Principal In- 
vestigator consortia and with important participation from NASA. 
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More information on scientific goals and results of the Herschel mission can be found 
on the Herschel Science Center websitd3- 

The development, management and the scientific exploitation of a complex mis- 
sion as Herschel required the development of a large software system (the Herschel 
Common Software System, HCSS). The HCSS was developed by a large pool of de- 
velopers and scientists of ESA, NASA and Instrument Control Centres institutes, dis- 
tributed in many countries (Europe, USA, Canada, China). The HCSS is written in Java 
and it is open source, released under the GNU Lesser General Public License v3. 

The Herschel Interactive Processing Environment (HIPE, ?) is a major compo- 
nent of the HCSS that was developed to provide the astronomical community and the 
instrument teams a complete environment to process and analyze the data gathered by 
Herschel. 

As all data analysis systems, HIPE needs a tool to produce plots. Several open 
source java plotting libraries are already available (e.g. JFreeChart and the SGT Li- 
brary), however the astronomical community has its own standards for the style of 
plots, e.g. the plot has to be in a closed box, with axis ticks oriented inward, etc. as in 
plots produced with IDL0 widely used by the astronomical community. 

In order to meet these requirements, after the evaluation of available libraries, we 
implemented our own plotting system. The development started from the SGT library 
code, which was later fully replaced with new code. 

This new plotting system, called PlotXY, was developed by Jingjing Li as one 
of the Chinese contributions to the mission. P. Panuzzo and J. Bakker contributed to 
the code development. This poster presents PlotXY features, architecture and future 
developments. 

2. PlotXY Features 

PlotXY allows to plot data on a 2D Cartesian coordinate system. It doesn't support 3D 
plots, pie plots, nor polar plots. The type of data that can be displayed are: a) pairs of 
1 dimensional arrays (X,Y), b) pairs of 1 dimensional arrays with errors, c) 2D scalar 
arrays (like an intensity map, see Fig. Q] left-bottom panel), d) 3 colors images (to 
be included in HIPE soon, Fig. Q] right-bottom panel). It could be easily extended to 
display vectorial fields. 

Data are displayed in a drawing box delimited by axes (see Fig. [Jleft-top panel, for 
a simple example), as is typically required in astronomical publications. It is however 
possible to make open plots by removing some of the axes (e.g. Fig. Q] right-top panel). 
Axes can be of different types: linear, logarithmic, astronomical coordinates, date. It is 
possible to define different scales in each axis of the drawing box, set the number or the 
position of minor and major ticks, as well the labels. 

Each set of data is displayed in a layer. One or more layers are associated to a 
drawing box, i.e. a subplot. One or more subplots are associated to a plot (see Fig. Q] 
right-top panel for an example of a plot with 2 subplots). 

Each layer has an associated style that describes how the data shall be displayed, 
i.e. the chart type (histogram or normal), symbols, line type (solid, marked, symbols, 
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Figure 1 . Various examples of plots generated with PlotX Y. 



dashed), color, stroke etc. It is also possible to add several type of annotations to a plot, 
like a text, an horizontal or vertical line, a rectangle area (Fig. [T] center-top). Finally it 
is also possible to add grid lines. All properties of all components (e.g. colors, fonts, 
axis ranges, line styles etc.) can be changed interactively via a property panel or via 
methods calls. 

The system provides an interactive zoom, i.e. the user can select with the mouse a 
region of interest and zoom in it, or zoom in and out with the mouse wheel. The user 
can also obtain the coordinates of a mouse click on the plot. PlotXY also provides a 
batch mode to postpone rendering when many plotting properties and data are changed 
at the same time. Plots can be exported to JPEG, PNG, EPS and PDF files. Plots can 
be shown in a dedicated window or used inside a container of an external GUI. 



3. Architecture 

The implementation is divided in 2 parts: 1) the classes used by the user to create the 
plots and 2) the engine classes that take care of the rendering of the data. Fig. |2] shows 
an UML class diagram of user classes. 

The separation of the user classes from engine classes allows for a greater flexibil- 
ity and modular development. In this way the engine classes can be modified without 
affecting the user API and, in principle, the design allows to have several sets of switch- 
able engines. 
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User actions (like changing a line style) trigger actions of the engines (like new 
rendering of the data). These commands are executed in a thread-safe mode by exe- 
cuting them in the EDT (Event Dispatcher Thread). In order to get good performances 
when the user changes continuously the data to be displayed, we use multi-thread ren- 
dering, i.e. each new request of rendering due to a change of the data is executed in a 
new thread. 




Figure 2. UML class diagram of PlotXY user classes. 



4. The jplot2d project 

Jplot2d is a re-implementation of the Herschel PlotXY. It is intended to be a plotting 
library that can be used by any other java application and it is independent from the rest 
of Herschel code base. 

Jplot2d has an improved design and more features, like: 

• Thread-safe by synchronization in proxy 

• Rendered result of plot components can be cached 

• Display-dependent components separated from core classes, so that it can be used 
in servlets 

• Neat architecture with less classes and more flexibility. Plots can contain other 
plots (no need of specific classes for subplots), layers can contains multiple sets 
of data 

Jplot2d is still in early development. It is released under the LGPL3 and it can be 
downloaded from URL http : //code, google. com/p/jplot2d/. 
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